

# **Application Note**

**Document No.: AN1097** 

# **APM32F035\_MOTOR EVAL Senseless Vector**

# **Control Scheme**

Version: V1.1

© Geehy Semiconductor Co., Ltd.



# Contents

| 1   | General Introduction                 |
|-----|--------------------------------------|
| 1.1 | Project Overview                     |
| 1.2 | APM32F035 Chip Resources             |
| 2   | Hardware Introduction5               |
| 2.1 | Overall Hardware Circuit             |
| 2.2 | Interface Circuits and Settings      |
| 2.3 | Physical System Hardware9            |
| 3   | Software Introduction11              |
| 3.1 | Overall Program Architecture         |
| 3.2 | Introduction to State Machine        |
| 3.3 | Top-layer Peripheral Configuration14 |
| 3.4 | Settings of Key Parameters17         |
| 4   | Actual test waveform20               |
| 5   | Revision History21                   |



# **1 General Introduction**

# 1.1 **Project Overview**

APM32F035 is a specialized chip launched by Geehy Semiconductor Co., Ltd. for motor control. Based on APM32F035, this design provides a dual-resistance sampling vector control scheme and uses the closed-loop sliding-mode observer estimation scheme. The detailed design specifications are shown in the table below:

| Control mode         | Position Sensorless Field Oriented Control (FOC)     |  |
|----------------------|------------------------------------------------------|--|
| Observer             | Sliding-mode observer+PLL                            |  |
| PWM modulation mode  | SVPWM                                                |  |
| PWM frequency        | 8KHz                                                 |  |
| Motor speed          | 400~3000RPM (2 pairs of poles)                       |  |
| Starting mode        | Open-loop starting                                   |  |
| Protection function  | Overvoltage, undervoltage, overcurrent, locked rotor |  |
| Code size            | 11Kbytes                                             |  |
| Development software | Keil C (V5.23 version and above)                     |  |

#### Table 1 Design Specifications

# 1.2 APM32F035 Chip Resources

APM32F035 is a high-performance special MCU for motor control which is based on the Arm Cortex-M0+ core, integrates the mathematical operation accelerators (Cordic, SvPWM, hardware divider, etc.) commonly used in FOC algorithms, and integrates such analog peripherals as amplifiers and comparators, as well as CAN controllers.

| Product                            |                        | APM32F035                      |                         |
|------------------------------------|------------------------|--------------------------------|-------------------------|
| Model                              |                        | C8T7                           | K8T7                    |
| Package                            |                        | LQFP48                         | LQFP32                  |
| Core and maximum working frequency |                        | Arm <sup>®</sup> 32-bit Cortex | <sup>®</sup> -M0+@72MHz |
| M0CP Co-processor                  |                        | 1                              |                         |
| Flash memory (KB)                  |                        | 64                             |                         |
| SRAM(KB)                           |                        | 10                             |                         |
| Timer                              | 32 bit/1 bit universal | I 1/2                          |                         |
|                                    | 16-bit advanced        | 1                              |                         |

Table 2 Functions and Peripherals of APM32F035 Series Chip



| Product                    |                  | APM32F035                                    |      |
|----------------------------|------------------|----------------------------------------------|------|
| Model                      |                  | C8T7                                         | K8T7 |
| 16-bit basic               |                  | 2                                            |      |
|                            | 24-bit counter   | 1                                            |      |
|                            | Watchdog (WDT)   | 2 (1 independent watchdog+1 window watchdog) |      |
|                            | Real-time clock  | 1                                            |      |
|                            | USART            | 2                                            |      |
| Communication interface    | SPI/I2S          | 1/1                                          |      |
| Communication interface    | I2C              | 1                                            |      |
|                            | CAN              | 1                                            |      |
|                            | Unit             | 1                                            |      |
| 12-bit ADC                 | External channel | 16                                           | 12   |
|                            | Internal channel | 3                                            |      |
| Comparator                 | (COMP)           | 2                                            |      |
| Operationalamplifier (OPA) |                  | 4                                            | 2    |
| GPIOs                      |                  | 42                                           | 27   |
| Operating temperature      |                  | Ambient temperature<br>Junction temperature  |      |
| Working voltage            |                  | 2.0~3.                                       | 6V   |



# 2 Hardware Introduction

# 2.1 **Overall Hardware Circuit**

The overall hardware system is powered by an external 24V power supply and after conversion through the corresponding power step-down circuit, it outputs stable 12V, 5V, and 3.3V voltages. The 12V voltage is output to the Gate driver IC, the 3.3V voltage is output to the APM32F035 series microprocessor, and the power switch tube is directly connected to the 24V power supply. At the same time, this scheme uses a variable resistance knob to adjust the voltage input of 0~3.3V as the input end of the speed command, in order to adjust the motor speed. Users can directly adjust the input voltage by turning the variable resistor knob in actual use. When the input voltage value exceeds the starting threshold, the motor will start running, and when the voltage value is below the threshold, the motor will stop running.

After the motor is started, the APM32F035 processor can obtain the phase currents lu, lv, and lw of three phases through the built-in operational amplifier and corresponding sampling circuit, and convert this data through the coordinate axis to control the torque current and phase of the motor. After the FOC control calculation link, adjust the TMR1 peripheral to output the corresponding three-way complementary PWM waves to control the switching components of the inverter.

The hardware block diagram is shown in the figure.







# 2.2 Interface Circuits and Settings

2.2.1 Power circuit







As shown in the figure, supply voltage V\_BUS =VM/((100K+100K+10K)/10K)=VM/21 A 12-bit ADC is adopted, and the sampling range 0-3.3V corresponds to 0-4096 Then the maximum sampling voltage corresponding to 3.3V is: VM= 3.3 \*21 =69.3V

#### 2.2.2 Phase Current Sampling Circuit









As shown in the figure, IU=UI\*5+1.65

A 12-bit ADC is adopted, and the sampling range 0-3.3V corresponds to 0-4096

As shown in Figure 2-3, when the sampling resistance is selected as 0.02R,

the maximum peak-to-peak current corresponding to 3.3V is (3.3-1.65)/5/0.02=16.5A.



#### 2.2.3 Overcurrent protection circuit



As shown in the figure, a built-in operational amplifier OPA4 is used to sample the bus current. A 12-bit ADC is adopted with a sampling range of 0-3.3V corresponding to 0-4096. From Figure 2-3, it can be seen that the sampling resistance is 0.02R;

The output end of OPA4 is used as the reverse input end of COMP1, and resistance voltage division is adopted at the forward input end. Through simple calculation, it can be concluded that the input is 3V;

Then the maximum current corresponding to 3V is (3-1.65)/5/0.02=13.5A.

#### 2.2.4 Minimum system circuit

#### Figure 6 Minimum System Circuit



As shown in the figure, the utilization of APM32F035 MOTOR EVAL V1.0 board hardware interface resources is described in the above figure. The external crystal oscillator input of HSE is 8MHz, and SWD burning interface is adopted for burning.



#### 2.2.5 Communication Interface and Button Circuit



Figure 7 Communication Interface and Button Circuit

As shown in the figure, a USB-to-serial port and a fault indicator light are reserved in the APM32F035 MOTOR EVAL V1.0 board hardware for debugging by developers; the two buttons are responsible for implementing the functions of controlling the running direction of the motor and locking.

# 2.3 **Physical System Hardware**

The picture of the system is shown in the figure, and it mainly includes the following four interfaces:

- (1) Power input interface (connect to 24V; pay attention to positive and negative poles)
- (2) Three phase motor interface (phase sequence only affects the direction of rotation)
- (3) HALL input interface
- (4) SWD debugging interface





#### Figure 8 Hardware Picture



# 3 Software Introduction

### 3.1 **Overall Program Architecture**

The overall code architecture of this project can be divided into four layers: user layer, peripheral driver layer, motor control driver layer, and motor algorithm layer. The specific functional descriptions are as follows:

#### 3.1.1 USER Layer

main.c: The main function entry is responsible for switching of motor initialization parameters, underlying peripherals, interrupt priority, while cycle, and low-speed state machine loop;

apm32f035\_int.c: All interrupt handling functions, mainly including TMR1 interrupt function and ADC interrupt handler function;

user\_function.c: Includes initialization configuration, parameter reset, and other handler functions of motor parameters;

parameter.h: Includes all required configuration parameter information;

board.c: Includes initialization configuration functions of board-level underlying peripheral.

#### 3.1.2 Peripheral Driver Layer (HARDWARE Layer)

The peripheral driver layer is mainly responsible for the peripheral driver functions and configuration of the APM32F035 chip, mainly including GPIO, PWM, ADC, OPA, COMP and M0CP coprocessors, as shown in the following figure.



Figure 9 Peripheral Driver Layer



#### 3.1.3 Motor Control Drive Layer (MOTOR\_CONTROL Layer)

The motor control driver layer is mainly responsible for the control run logic and core processing algorithm call of the motor, as shown in the following figure.

#### Figure 10 Motor Control Driver Layer



#### 3.1.4 Geehy Motor Algorithm Layer (Geehy\_MCLIB Layer)

The motor algorithm layer includes coordinate transformation, vector control and other related functions, as well as math libraries, sliding-mode observer and other library functions.

#### 3.2 Introduction to State Machine

In this case, the structure of embedding the sub-state machine into the main state machine is adopted, as shown below:

Four main states: INIT, STOP, FAIL, and RUN;

The six RUN sub-states of the main state are **run calib**, **run-ready**, **run-align**, **run-startup**, **run-spin**, **and run-freewheel**.

The main state machine is described below:

**Fault:** When an error occurs in the system, it will remain in this state until the error flag bit is cleared;

Then after delay for a period of time, it will jump from the Fault state to the STOP state and wait for the start command.

Init: This main state executes variable initialization.

**Stop:** The system waits for the speed command after completing initialization. In this state, the PWM output is turned off.



Run: In the running state, if a Stop command is issued, the system will stop running.

When the system is running in the Run state, its sub-states will be called and executed.

**Run-Calib:** The current biased ADC self-calibration function can be executed. After this state is executed, the system will switch to the Ready state and disable the PWM output.

**Ready:** Enable PWM output, synchronously sample the current, and conduct abnormal state inspection.

**Align:** Execute sampling current, call pre-positioning algorithm, and update the PWM. Execute the state within the specified time, and the system will switch to the Startup sub-state and sample the DC bus voltage for filtering.

**Startup:** Sample the current, use an open-loop starting motor, and call the observer to estimate the rotor speed and position, call the corresponding algorithm, and update the PWM. If the motor is started successfully, the system will spin the sub-state and sample the DC bus voltage for filtering.

**Spin:** Sample the current, call the observer to estimate the rotor speed and position, call the corresponding algorithm, update the PWM, and the motor starts to switch to closed-loop operation.

**Freewheel:** Enable PWM output and stop the machine through shorting the brake. Due to rotor inertia, the state can be switched only after the motor stops running and further switched to Ready state. If an error occurs, the system will enter the Fault state.

To sum up, the state machine flowchart of the system is shown in the figure below.



Figure 11 State Machine Flowchart



# 3.3 **Top-layer Peripheral Configuration**

#### 3.3.1 PWM Output Configuration

void Drv\_Pwm\_Init(uint16\_t u16\_Period,uint16\_t u16\_DeadTime)

(1) The general configuration of PWM is as follows:

Set the PWM clock frequency division to 1, select the center-aligned mode 2, and set the repeat counter to 1, as shown in the figure below.

| Figure 12 | General Configuration of PWM |
|-----------|------------------------------|
|-----------|------------------------------|

..../\*.Time.Base.configuration.,init.timel.freq\*/ ....TIM\_TimeBaseInitStructure.period......=.ul6\_Period; ....TIM\_TimeBaseInitStructure.div.....=.o; ....TIM\_TimeBaseInitStructure.counterMode....=TMR\_COUNTER\_MODE\_CENTERALIGNED2; ....TIM\_TimeBaseInitStructure.clockDivision...=TMR\_CKD\_DIV1; ....TIM\_TimeBaseInitStructure.peptitionCounter:=.1; ....TMR\_ConfigTimeBase(TMR1,.4TIM\_TimeBaseInitStructure);

Figure 13 Center-aligned Mode Selection

Center Aligned Mode Select +

In the Center-aligned mode, the counter counts up and down alternately; otherwise, it will only count up or down. Different Center-aligned modes affect the timing of setting the output comparison interrupt flag bit of the output channel to 1; when the counter is disabled (CNTEN=0), select the Center-aligned mode.

- 00: Edge alignment mode
- 01: Center-aligned mode 1 (the output comparison interrupt flag bit of output channel is set to 1 when counting down)
- 10: Center-aligned mode 2 (the output comparison interrupt flag bit of output channel is set to 1 when counting up)
- 11: Center-aligned mode 3 (the output comparison interrupt flag bit of output channel is set to 1 when counting up/down)
- (2) PWM Output Status Configuration

Set the output status of upper and lower tubes of PWM and enable the configuration of PWM output of the upper and lower tubes to be effective,

configure the enabled brakes, configure the brake input polarity, and disable automatic recovery of brake hardware.



#### Figure 14 PWM Output Status Configuration

```
/* Automatic Output enable, Break, dead time and lock configuration*/
TIM_BDTRInitStructure.RMOS_State TMR_RMOS_STATE_ENABLE;
TIM BDTRInitStructure.IMOS_State .... TMR_IMOS_STATE_ENABLE;
TIM_BDTRInitStructure.lockLevel .... TMR_LOCK_LEVEL_OFF;
TIM BDTRInitStructure.deadTime ....= ul6 DeadTime;//
/*
· · * ·Brake · configuration: · enable · brake
· ·* ·Brake · input · polarity: ·active · in · low · level · · ·

· * ·Auto · output · enable · configuration: ·Disable ·MOE · bit · hardware · control

. . */
TIM_BDTRInitStructure.breakState .... = TMR_BREAK_STATE_ENABLE;
TIM BDTRInitStructure.breakPolarity --- TMR BREAK POLARITY LOW;
TIM BDTRInitStructure.automaticOutput = TMR_AUTOMATIC_OUTPUT_DISABLE;
TMR_ConfigBDT (TMR1, &TIM_BDTRInitStructure);
/*pwm·driver·set, channel·1,2,3,4set·pwm·mode*/
TIM_OCInitStructure.OC_Mode ..... TMR_OC_MODE_PWM2;
TIM_OCInitStructure.OC_OutputState = TMR_OUTPUT_STATE_ENABLE; //TMR_OUTPUT_STATE_DISABLE;
TIM_OCInitStructure.OC_OutputNState = TMR_OUTPUT_NSTATE_ENABLE; //TMR_OUTPUT_NSTATE_DISABLE;
TIM OCInitStructure.Pulse .....= 0;
TIM_OCInitStructure.OC_Polarity ----= TMR_OC_POLARITY_HIGH;
TIM OCInitStructure.OC NPolarity --- TMR OC NPOLARITY HIGH;
TIM OCIDItStructure.OC Idlestate = TMR OCIDLESTATE RESET; // TMR OCIDLESTATE SET; //
TIM OCInitStructure.OC NIdlestate = TMR OCNIDLESTATE RESET; // TMR OCNIDLESTATE SET;//
```

Figure 15 Timing Diagram of PWM2 Center-aligned Mode



In count-up mode, when TMR1\_CNT<TMR1\_CCR1, Channel 1 is invalid level; otherwise it is valid level;

In count-down mode, when TMR1\_CNT>TMR1\_CCR1, Channel 1 is valid level; otherwise it is invalid level.

#### 3.3.2 ADC Configuration

void Drv\_Adc\_Init(void)

1. ADC underlying configuration

DMA mode is adopted, and the quantized data of ADC is directly transported to the ADC\_ConvertedValue array for storage. The ADC trigger condition uses CC4 of TMR1 as the trigger source, to enable ADC and configure ADC interrupt priority and its enable. Details are shown below:



#### Figure 16 ADC Underlying Configuration



#### 3.3.3 OPA and COMP Underlying Configuration

1. OPA underlying configuration

To configure the underlying configuration of OPA, first configure the OPA pin, DISABLE the operational amplifier OPA, configure to use an external resistor network, and then ENABLE it, as shown in the figure below;





1. COMP underlying configuration

COMP is used for overcurrent anomaly detection. To configure the underlying configuration of COMP, first configure the COMP pin, set the COMP output to the BKIN connected to TMR1, set the output reverse, and trigger the BKIN of TMR1 at a low level, as shown in the following figure;

Figure 18 COMP Underlying Configuration

### 3.4 Settings of Key Parameters

All parameters in this system are configured in parameter.h of the user layer, mainly including system parameters, related parameters of backplane, related parameters of state machine, and related parameters of motor, as follows:

#### 3.4.1 System Parameters

| Table 3 System | Parameters |
|----------------|------------|
|----------------|------------|

| Parameter name   | Parameter description          | Set value     |
|------------------|--------------------------------|---------------|
| SYS_REFV         | Supply voltage of the system   | 3.3 (V)       |
| SYSCLK_HSE_72MHz | Main frequency of the system   | 72000000 (Hz) |
| PWMFREQ          | PWM frequency                  | 8000 (Hz)     |
| DEAD_TIME        | PWM dead band time             | 1.0 (µs)      |
| SLOWLOOP_FREQ    | Control frequency of slow loop | 1000 (Hz)     |



#### 3.4.2 Backplane Hardware Parameters

| Parameter name   | Parameter description                         | Set value |
|------------------|-----------------------------------------------|-----------|
| ADC_REFV         | ADC reference voltage                         | 3.3 (V)   |
| R_SHUNT          | Sampling resistance value                     | 0.02 (Ω)  |
| CURRENT_OPA_GAIN | Amplification factor of operational amplifier | 5.0       |
| I_MAX            | Current standardization reference<br>value    | 16.5 (A)  |
| UDC_MAX          | Voltage standardization reference<br>value    | 69.0 (V)  |
| U_MAX            | Phase voltage standardization reference value | 39.83 (V) |

#### Table 4 Parameters of Backplane Hardware

#### 3.4.3 Parameters of State Machine

#### Table 5 Parameters of State Machine

| Parameter name        | Parameter description                        | Set value   |
|-----------------------|----------------------------------------------|-------------|
| STOP_TO_RUN_SPEED     | Threshold for speed command of jumping from  | 500 (rpm)   |
|                       | Stop to Run state                            | 300 (ipiii) |
| STARTUP TO SPIN SPEED | Threshold for actual speed of jumping from   | 400 (rpm)   |
|                       | Startup to Spin state                        | 400 (ipili) |
| FREEWHEEL SPEED       | Stop after the speed command is below the    | 400 (rpm)   |
|                       | threshold                                    | 400 (ipiii) |
| IQ_ALIGN              | IQ command value in Align state              | 1.0 (A)     |
| MAXSTARTUP_SPEED      | Maximum speed of open-loop rotation          | 500 (rpm)   |
| STARTUP_SPEED_RAMP    | Slope value of speed command under open loop | 500 (rpm/s) |
| STARTUP_TIME          | Open-loop time                               | 1.0 (s)     |

#### 3.4.4 Motor Related Parameters

#### Table 6 Motor Related Parameters

| Parameter name | Parameter description      | Set value   |
|----------------|----------------------------|-------------|
| Rs             | Phase resistance of motor  | 0.15 (ohm)  |
| Ls             | Phase inductance of motor  | 0.00037 (H) |
| POLEPAIRS      | Number of motor pole-pairs | 2 (unit)    |
| SPEED_MAX      | Speed calibration value    | 5000 (rpm)  |



| Parameter name  | Parameter description                                    | Set value   |
|-----------------|----------------------------------------------------------|-------------|
| MAX_DUTY        | Maximum duty cycle                                       | 0.92 (unit) |
| M1_IQ_KP_Q15    | Q-axis current loop KP parameter Q15 format              | 980         |
| M1_IQ_KI_Q15    | Q-axis current loop KI parameter Q15 format              | 220         |
| M1_ID_KP_Q15    | M1_ID_KP_Q15 D-axis current loop KP parameter Q15 format |             |
| M1_ID_KI_Q15    | D-axis current loop KI parameter Q15 format              | 220         |
| M1_SPEED_KP_Q15 | Speed loop KP parameter Q15 format                       | 16384       |
| M1_SPEED_KI_Q15 | Speed loop KI parameter Q15 format                       | 163         |



# 4 Actual test waveform



#### Figure 19 Actual Test Waveform



# 5 **Revision History**

#### Table 7 Document Revision History

| Date            | Revision | Revision History                             |
|-----------------|----------|----------------------------------------------|
| July 26, 2023   | 1.0      | New                                          |
| August 14, 2023 | 1.1      | (1) Modified the production information form |
|                 |          | (2) Modified the format                      |



# Statement

This document is formulated and published by Geehy Semiconductor Co., Ltd. (hereinafter referred to as "Geehy"). The contents in this document are protected by laws and regulations of trademark, copyright and software copyright. Geehy reserves the right to make corrections and modifications to this document at any time. Please read this document carefully before using Geehy products. Once you use the Geehy product, it means that you (hereinafter referred to as the "users") have known and accepted all the contents of this document. Users shall use the Geehy product in accordance with relevant laws and regulations and the requirements of this document.

#### 1. Ownership

This document can only be used in connection with the corresponding chip products or software products provided by Geehy. Without the prior permission of Geehy, no unit or individual may copy, transcribe, modify, edit or disseminate all or part of the contents of this document for any reason or in any form.

The "极海" or "Geehy" words or graphics with "®" or "<sup>TM</sup>" in this document are trademarks of Geehy. Other product or service names displayed on Geehy products are the property of their respective owners.

2. No Intellectual Property License

Geehy owns all rights, ownership and intellectual property rights involved in this document.

Geehy shall not be deemed to grant the license or right of any intellectual property to users explicitly or implicitly due to the sale or distribution of Geehy products or this document.

If any third party's products, services or intellectual property are involved in this document, it shall not be deemed that Geehy authorizes users to use the aforesaid third party's products, services or intellectual property, unless otherwise agreed in sales order or sales contract.

#### 3. Version Update

Users can obtain the latest document of the corresponding models when ordering Geehy products.



If the contents in this document are inconsistent with Geehy products, the agreement in thesales order or the sales contract shall prevail.

#### 4. Information Reliability

The relevant data in this document are obtained from batch test by Geehy Laboratory or cooperative third-party testing organization. However, clerical errors in correction or errors caused by differences in testing environment may occur inevitably. Therefore, users should understand that Geehy does not bear any responsibility for such errors that may occur in this document. The relevant data in this document are only used to guide users as performance parameter reference and do not constitute Geehy's guarantee for any product performance.

Users shall select appropriate Geehy products according to their own needs, and effectively verify and test the applicability of Geehy products to confirm that Geehy products meet their own needs, corresponding standards, safety or other reliability requirements. If loses are caused to users due to the user's failure to fully verify and test Geehy products, Geehy will not bear any responsibility.

5. Legality

USERS SHALL ABIDE BY ALL APPLICABLE LOCAL LAWS AND REGULATIONS WHEN USING THIS DOCUMENT AND THE MATCHING GEEHY PRODUCTS. USERS SHALL UNDERSTAND THAT THE PRODUCTS MAY BE RESTRICTED BY THE EXPORT, RE-EXPORT OR OTHER LAWS OF THE COUNTIRIES OF THE PRODUCTS SUPPLIERS, GEEHY, GEEHY DISTRIBUTORS AND USERS. USERS (ON BEHALF OR ITSELF, SUBSIDIARIES AND AFFILIATED ENTERPRISES) SHALL AGREE AND PROMISE TO ABIDE BY ALL APPLICABLE LAWS AND REGULATIONS ON THE EXPORT AND RE-EXPORT OF GEEHY PRODUCTS AND/OR TECHNOLOGIES AND DIRECT PRODUCTS.

#### 6. Disclaimer of Warranty

THIS DOCUMENT IS PROVIDED BY GEEHY "AS IS" AND THERE IS NO WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, TO THE



#### EXTENT PERMITTED BY APPLICABLE LAW.

GEEHY WILL BEAR NO RESPONSIBILITY FOR ANY DISPUTES ARISING FROM THE SUBSEQUENT DESIGN OR USE BY USERS.

7. Limitation of Liability

IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL GEEHY OR ANY OTHER PARTY WHO PROVIDE THE DOCUMENT "AS IS", BE LIABLE FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, DIRECT, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE DOCUMENT (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY USERS OR THIRD PARTIES).

8. Scope of Application

The information in this document replaces the information provided in all previous versions of the document.

© 2023 Geehy Semiconductor Co., Ltd. - All Rights Reserved

# Geehy Semiconductor Co.,Ltd.

Ø Bldg.1, No.83 Guangwan Street, Zhuhai, Guangdong, China